<template>
    <div class="default-main">
        <div class="banner">
            <el-row :gutter="10">
                <el-col :md="24" :lg="18">
                    <div class="welcome suspension">
                        <img class="welcome-img" :src="headerSvg" alt="" />
                        <div class="welcome-text">
                            <div class="welcome-title" style="font-weight: bold;">{{ data.name }}</div>
                            <div class="welcome-note">
                                    <p>当前版本：<el-tag type="success">外卖点餐专业版</el-tag></p>
                                    <p>开通时间：{{ data.kai_time }}</p>
                                    <p>到期时间：{{ data.end_time }}</p>
                            </div>
                        </div>
                    </div>
                </el-col>
                <el-col :lg="6" class="hidden-md-and-down">
                    <div class="working">
                        <img class="working-coffee" :src="coffeeSvg" alt="" />
                        <div class="working-text">
                            {{ t('dashboard.You have worked today') }}<span class="time">{{ state.workingTimeFormat }}</span>
                        </div>
                        <div @click="onChangeWorkState()" class="working-opt working-rest">
                            {{ state.pauseWork ? t('dashboard.Continue to work') : t('dashboard.have a bit of rest') }}
                        </div>
                    </div>
                </el-col>
            </el-row>
        </div>
        <div class="small-panel-box">
            <el-row :gutter="20">
                <el-col :sm="12" :lg="6">
                    <div class="small-panel user-reg suspension">
                        <div class="small-panel-title">今日新增用户</div>
                        <div class="small-panel-content">
                            <div class="content-left">
                                <Icon color="#8595F4" size="20" name="fa fa-user" />
                                <span id="user_reg_number22">{{ sumdata.newuser}}</span>
                            </div>
                            <div class="content-right">+14%</div>
                        </div>
                    </div>
                </el-col>
                <el-col :sm="12" :lg="6">
                    <div class="small-panel file suspension">
                        <div class="small-panel-title">今日订单金额</div>
                        <div class="small-panel-content">
                            <div class="content-left">
                                <Icon color="#AD85F4" size="20" name="fa fa-file-text" />
                                <span id="file_number">{{ sumdata.today_order }}</span>
                            </div>
                            <div class="content-right">+50%</div>
                        </div>
                    </div>
                </el-col>
                <el-col :sm="12" :lg="6">
                    <div class="small-panel users suspension">
                        <div class="small-panel-title">销售总金额</div>
                        <div class="small-panel-content">
                            <div class="content-left">
                                <Icon color="#74A8B5" size="20" name="fa fa-money" />
                                <span id="users_number">{{ sumdata.sum_order }}</span>
                            </div>
                            <div class="content-right">+28%</div>
                        </div>
                    </div>
                </el-col>
                <el-col :sm="12" :lg="6">
                    <div class="small-panel addons suspension">
                        <div class="small-panel-title">待退款订单</div>
                        <div class="small-panel-content">
                            <div class="content-left">
                                <Icon color="#F48595" size="20" name="fa fa-object-group" />
                                <span id="addons_number">{{ sumdata.tui_order }}</span>
                            </div>
                            <div class="content-right">+88%</div>
                        </div>
                    </div>
                </el-col>
                
            </el-row>
        </div>
        <div class="growth-chart">
            <el-row :gutter="20">
                <el-col class="lg-mb-20" :xs="24" :sm="24" :md="12" :lg="9">
                    <el-card shadow="hover" header="近7日新增用户统计">
                        <div class="user-growth-chart" id="day_user"></div>
                    </el-card>
                </el-col>
                <el-col class="lg-mb-20" :xs="24" :sm="24" :md="12" :lg="9">
                    <el-card shadow="hover" header="订单状态统计">
                        <div class="file-growth-chart" id="os_sale"></div>
                    </el-card>
                </el-col>
                <el-col :xs="24" :sm="24" :md="24" :lg="6">
                    <el-card class="new-user-card" shadow="hover" header="快捷操作">
                        <div class="new-user-growth">
                            <el-scrollbar>
                                <div class="new-user-item">
                                    <router-link to="/admin/goods/goods">
                                        <img class="new-user-avatar" src="~assets/index_pro.svg" alt="" />
                                        <div class="new-user-base">
                                            <div class="new-user-name">商品管理</div>
                                        </div>
                                    </router-link>
                                </div>
                                <div class="new-user-item">
                                    <router-link to="/admin/order/order">
                                        <img class="new-user-avatar" src="~assets/index_gold.svg" alt="" />
                                        <div class="new-user-base">
                                            <div class="new-user-name">订单管理</div>
                                        </div>
                                    </router-link>
                                </div>
                                <div class="new-user-item">
                                    <router-link to="/admin/user/user">
                                        <img class="new-user-avatar" src="~assets/index_huncun.svg" alt="" />
                                        <div class="new-user-base">
                                            <div class="new-user-name">用户管理</div>
                                        </div>
                                    </router-link>
                                </div>
                                <div class="new-user-item">
                                    <router-link to="/admin/mk/coupon">
                                        <img class="new-user-avatar" src="~assets/index_zhe.svg" alt="" />
                                        <div class="new-user-base">
                                            <div class="new-user-name">优惠券</div>
                                        </div>
                                    </router-link>
                                </div>
                                <div class="new-user-item">
                                    <router-link to="/admin/statics/order">
                                        <img class="new-user-avatar" src="~assets/index_neirong2.svg" alt="" />
                                        <div class="new-user-base">
                                            <div class="new-user-name">数据统计</div>
                                        </div>
                                    </router-link>
                                </div>
                                <div class="new-user-item">
                                    <router-link to="/admin/statics/rank">
                                        <img class="new-user-avatar" src="~assets/index_mess.svg" alt="" />
                                        <div class="new-user-base">
                                            <div class="new-user-name">数据排行</div>
                                        </div>
                                    </router-link>
                                </div>
                                <div class="new-user-item">
                                    <router-link to="/admin/auth/adminLog">
                                        <img class="new-user-avatar" src="~assets/index_news.svg" alt="" />
                                        <div class="new-user-base">
                                            <div class="new-user-name">日志管理</div>
                                        </div>
                                    </router-link>
                                </div>
                                <div class="new-user-item">
                                    <router-link to="/admin/store/settings">
                                        <img class="new-user-avatar" src="~assets/index_tkd2.svg" alt="" />
                                        <div class="new-user-base">
                                            <div class="new-user-name">系统设置</div>
                                        </div>
                                    </router-link>
                                </div>
                            </el-scrollbar>

                        </div>
                    </el-card>
                </el-col>
            </el-row>
        </div>

        <div class="growth-chart">
            <el-row :gutter="20">
                <el-col class="lg-mb-20" :xs="24" :sm="24" :md="24" :lg="24">
                    <el-card shadow="hover" header="订单">
                        <div class="user-source-chart" id="order_sale"></div>
                    </el-card>
                </el-col>
                
            </el-row>
        </div>
    </div>
</template>

<script setup lang="ts">
import { onMounted, onUnmounted, reactive, nextTick, onActivated, watch, onBeforeMount ,ref} from 'vue'
import headerSvg from '/@/assets/dashboard/header-1.svg'
import coffeeSvg from '/@/assets/dashboard/coffee.svg'
import { CountUp } from 'countup.js'
import * as echarts from 'echarts'
import { useNavTabs } from '/@/stores/navTabs'
import { useTemplateRefsList } from '@vueuse/core'
import { index } from '/@/api/backend/dashboard'
import { useI18n } from 'vue-i18n'
import { Local } from '/@/utils/storage'
import { useAdminInfo } from '/@/stores/adminInfo'
import { WORKING_TIME } from '/@/stores/constant/cacheKey'
import { fullUrl, getGreet } from '/@/utils/common'
import { useEventListener } from '@vueuse/core'
import createAxios from "/@/utils/axios";
let workTimer: number

defineOptions({
    name: 'dashboard',
})

const d = new Date()
const { t } = useI18n()
const navTabs = useNavTabs()
const adminInfo = useAdminInfo()
const chartRefs = useTemplateRefsList<HTMLDivElement>()
const data = ref([])
const sumdata = ref({})
const charts = ref([])
const state: {
    charts: any[]
    remark: string
    workingTimeFormat: string
    pauseWork: boolean
} = reactive({
    charts: [],
    remark: 'dashboard.Loading',
    workingTimeFormat: '',
    pauseWork: false,
})

index().then((res) => {
    state.remark = res.data.remark
})

const countUpFun = (id: string) => {
    nextTick(() => {
        let value = document.getElementById(id)?.innerText
        if (value) {
            new CountUp(id, parseInt(value), {
                startVal: 0,
                duration: 3,
            }).start()
        }
    })
}

const initCountUp = () => {
    countUpFun('user_reg_number')
    countUpFun('file_number')
    countUpFun('users_number')
    countUpFun('addons_number')
}

//订单状态分布
const initOrderStatusChart = () => {
    var game = charts.value.os_chart
    var s1 = []
    for (var i in game) {
        s1.push({ value: game[i].count, name: game[i].name })
    }
    var chartDom = document.getElementById('os_sale');
    var myChart = echarts.init(chartDom);
    var option = {
        tooltip: {
            trigger: 'item'
        },
        grid:{
            top:'125%'
        },
        legend: {
            top: '0%',
            left: 'center'
        },
        series: [
            {
                name: '订单量',
                type: 'pie',
                radius: ['40%', '70%'],
                avoidLabelOverlap: false,
                top:'15%',
                label: {
                    show: false,
                    position: 'center'
                },
                emphasis: {
                    label: {
                        show: true,
                        fontSize: 40,
                        fontWeight: 'bold'
                    }
                },
                labelLine: {
                    show: false
                },
                data: s1


            }
        ]
    };
    option && myChart.setOption(option);
}


//会员增长情况
const initUserGrowthChart = () => {
    var user_data_date = charts.value.date_9
    var user_data_num = charts.value.user_chart
    var s1 = []
    var s2 = []
    for (var i in user_data_date) {
        s1.push(user_data_date[i])
        s2.push(user_data_num[i])
    }
    var chartDom = document.getElementById('day_user');
    var myChart = echarts.init(chartDom);
    var option = {
        tooltip: {
                trigger: 'axis',
                axisPointer: {
                type: 'shadow'
                }
       },
        xAxis: {
            type: 'category',
            data: s1
        },
        yAxis: {
            type: 'value'
        },
        series: [
            {
            data: s2,
            type: 'line'
            }
        ]
    };
    option && myChart.setOption(option);
}

const initOrderChart = () => {
    var date = charts.value.date_15
    var order_data = charts.value.order_chart
    var s1 = []
    var s2 = []
    for (var i in date) {
        s1.push(date[i])
        s2.push(order_data[i])
    }
    var chartDom = document.getElementById('order_sale');
    var myChart = echarts.init(chartDom);
    var option = {
            tooltip: {
                trigger: 'axis',
                axisPointer: {
                type: 'shadow'
                }
            },
            grid: {
                left: '3%',
                right: '4%',
                bottom: '3%',
                containLabel: true
            },
            xAxis: [
                {
                type: 'category',
                data: s1,
                axisTick: {
                    alignWithLabel: true
                }
                }
            ],
            yAxis: [
                {
                type: 'value'
                }
            ],
            series: [
                {
                name: '订单额',
                type: 'bar',
                barWidth: '60%',
                data: s2
                }
            ]
            };
    option && myChart.setOption(option);
}

const echartsResize = () => {
    nextTick(() => {
        for (const key in state.charts) {
            state.charts[key].resize()
        }
    })
}

const onChangeWorkState = () => {
    const time = parseInt((new Date().getTime() / 1000).toString())
    const workingTime = Local.get(WORKING_TIME)
    if (state.pauseWork) {
        // 继续工作
        workingTime.pauseTime += time - workingTime.startPauseTime
        workingTime.startPauseTime = 0
        Local.set(WORKING_TIME, workingTime)
        state.pauseWork = false
        startWork()
    } else {
        // 暂停工作
        workingTime.startPauseTime = time
        Local.set(WORKING_TIME, workingTime)
        clearInterval(workTimer)
        state.pauseWork = true
    }
}

const startWork = () => {
    const workingTime = Local.get(WORKING_TIME) || { date: '', startTime: 0, pauseTime: 0, startPauseTime: 0 }
    const currentDate = d.getFullYear() + '-' + (d.getMonth() + 1) + '-' + d.getDate()
    const time = parseInt((new Date().getTime() / 1000).toString())

    if (workingTime.date != currentDate) {
        workingTime.date = currentDate
        workingTime.startTime = time
        workingTime.pauseTime = workingTime.startPauseTime = 0
        Local.set(WORKING_TIME, workingTime)
    }

    let startPauseTime = 0
    if (workingTime.startPauseTime <= 0) {
        state.pauseWork = false
        startPauseTime = 0
    } else {
        state.pauseWork = true
        startPauseTime = time - workingTime.startPauseTime // 已暂停时间
    }

    let workingSeconds = time - workingTime.startTime - workingTime.pauseTime - startPauseTime

    state.workingTimeFormat = formatSeconds(workingSeconds)
    if (!state.pauseWork) {
        workTimer = window.setInterval(() => {
            workingSeconds++
            state.workingTimeFormat = formatSeconds(workingSeconds)
        }, 1000)
    }
}

const formatSeconds = (seconds: number) => {
    var secondTime = 0 // 秒
    var minuteTime = 0 // 分
    var hourTime = 0 // 小时
    var dayTime = 0 // 天
    var result = ''

    if (seconds < 60) {
        secondTime = seconds
    } else {
        // 获取分钟，除以60取整数，得到整数分钟
        minuteTime = Math.floor(seconds / 60)
        // 获取秒数，秒数取佘，得到整数秒数
        secondTime = Math.floor(seconds % 60)
        // 如果分钟大于60，将分钟转换成小时
        if (minuteTime >= 60) {
            // 获取小时，获取分钟除以60，得到整数小时
            hourTime = Math.floor(minuteTime / 60)
            // 获取小时后取佘的分，获取分钟除以60取佘的分
            minuteTime = Math.floor(minuteTime % 60)
            if (hourTime >= 24) {
                // 获取天数， 获取小时除以24，得到整数天
                dayTime = Math.floor(hourTime / 24)
                // 获取小时后取余小时，获取分钟除以24取余的分；
                hourTime = Math.floor(hourTime % 24)
            }
        }
    }

    result =
        hourTime +
        t('dashboard.hour') +
        ((minuteTime >= 10 ? minuteTime : '0' + minuteTime) + t('dashboard.minute')) +
        ((secondTime >= 10 ? secondTime : '0' + secondTime) + t('dashboard.second'))
    if (dayTime > 0) {
        result = dayTime + t('dashboard.day') + result
    }
    return result
}

onActivated(() => {
    echartsResize()
})

onMounted(() => {
    startWork()
    initCountUp()
    return createAxios({
        url: '/admin/statics.Rank/dash',
        method: 'post',
        data: { 'pay_status': 1, 'from': 'dashboard' }
    }).then(res => {
        data.value = res.data.store
        sumdata.value = res.data.sumdata
        charts.value = res.data.charts

        initUserGrowthChart()
        initOrderStatusChart()
        initOrderChart()
    }).catch(err => {

    })


})

onBeforeMount(() => {
    for (const key in state.charts) {
        state.charts[key].dispose()
    }
})

onUnmounted(() => {
    clearInterval(workTimer)
})

watch(
    () => navTabs.state.tabFullScreen,
    () => {
        echartsResize()
    }
)
</script>

<style scoped lang="scss">
.welcome {
    background: #fff;
    border-radius: 6px;
    display: flex;
    align-items: center;
    padding: 15px 20px !important;
    box-shadow: 0 0 30px 0 rgba(82, 63, 105, 0.05);
    .welcome-img {
        height: 100px;
        margin-right: 10px;
        user-select: none;
    }
    .welcome-title {
        font-size: 1.5rem;
        line-height: 30px;
        color: var(--ba-color-primary-light);
    }
    .welcome-note {
        padding-top: 6px;
        font-size: 15px;
        color: var(--el-text-color-primary);
    }
}
.working {
    height: 130px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    height: 100%;
    position: relative;
    &:hover {
        .working-coffee {
            -webkit-transform: translateY(-4px) scale(1.02);
            -moz-transform: translateY(-4px) scale(1.02);
            -ms-transform: translateY(-4px) scale(1.02);
            -o-transform: translateY(-4px) scale(1.02);
            transform: translateY(-4px) scale(1.02);
            z-index: 999;
        }
    }
    .working-coffee {
        transition: all 0.3s ease;
        width: 80px;
    }
    .working-text {
        display: block;
        width: 100%;
        font-size: 15px;
        text-align: center;
        color: var(--el-text-color-primary);
    }
    .working-opt {
        position: absolute;
        top: -40px;
        right: 10px;
        background-color: rgba($color: #000000, $alpha: 0.3);
        padding: 10px 20px;
        border-radius: 20px;
        color: var(--ba-bg-color-overlay);
        transition: all 0.3s ease;
        cursor: pointer;
        opacity: 0;
        z-index: 999;
        &:active {
            background-color: rgba($color: #000000, $alpha: 0.6);
        }
    }
    &:hover {
        .working-opt {
            opacity: 1;
            top: 0;
        }
        .working-done {
            opacity: 1;
            top: 50px;
        }
    }
}
.small-panel-box {
    margin-top: 20px;
}
.small-panel {
    background-color: #fff;
    border-radius: var(--el-border-radius-base);
    padding: 25px;
    margin-bottom: 20px;
    .small-panel-title {
        color: #92969a;
        font-size: 15px;
    }
    .small-panel-content {
        display: flex;
        align-items: flex-end;
        margin-top: 20px;
        color: #2c3f5d;
        .content-left {
            font-size: 24px;
            .icon {
                margin-right: 10px;
            }
            span {
                display: inline-block;
                font-size: 28px;
            }
        }
        .content-right {
            font-size: 18px;
            margin-left: auto;
        }
        .color-success {
            color: var(--el-color-success);
        }
        .color-warning {
            color: var(--el-color-warning);
        }
        .color-danger {
            color: var(--el-color-danger);
        }
        .color-info {
            color: var(--el-text-color-secondary);
        }
    }
}
.growth-chart {
    margin-bottom: 20px;
}
.user-growth-chart,
.file-growth-chart {
    height: 260px;
}
.new-user-growth {
    height: 300px;
}

.user-source-chart,
.user-surname-chart {
    height: 400px;
}
.new-user-item {
    cursor: pointer;
    align-items: center;
    padding: 20px;
    // margin: 10px 15px;
    box-shadow: 0 0 30px 0 rgba(82, 63, 105, 0.05);
    background-color: var(--ba-bg-color-overlay);
    width: 49%;
    float: left;

    .new-user-avatar {
        height: 33px;
        width: 33px;
        border-radius: 50%;
        float: left;
    }

    .new-user-base {
        margin-left: 10px;
        color: #2c3f5d;
        float: left;
        padding-top: 6px;

        .new-user-name {
            font-size: 14px;
        }

        .new-user-time {
            font-size: 13px;
        }
    }

    .new-user-arrow {
        margin-left: auto;
    }
}
.new-user-card :deep(.el-card__body) {
    padding: 0;
}

@media screen and (max-width: 425px) {
    .welcome-img {
        display: none;
    }
}
@media screen and (max-width: 1200px) {
    .lg-mb-20 {
        margin-bottom: 20px;
    }
}
html.dark {
    .welcome {
        background-color: var(--ba-bg-color-overlay);
    }
    .small-panel {
        background-color: var(--ba-bg-color-overlay);
        .small-panel-content {
            color: var(--el-text-color-regular);
        }
    }
    .new-user-item {
        .new-user-base {
            color: var(--el-text-color-regular);
        }
    }
}
</style>
